$(function () {
  const layer = layui.layer;
  // 1.1 获取裁剪区域的 DOM 元素
  let $image = $("#image");
  // 1.2 配置选项
  const options = {
    // 纵横比
    aspectRatio: 1,
    // 指定预览区域
    preview: ".img-preview",
  };

  // 1.3 创建裁剪区域
  $image.cropper(options);

  // 点击上传按钮唤起上传文件功能
  $("#chooseimg").on("click", function () {
    $("#file").click();
  });

  // 更改图片 给input添加change事件
  $("#file").on("change", function (e) {
    console.log(e.target.files);
    let fileList = e.target.files;

    // 判断用户是否选择了图片
    if (fileList.length === 0) return layer.msg("请选择图片");

    // 1. 拿到用户选择的文件
    var file = e.target.files[0];

    // 2. 将文件，转化为路径
    var imgURL = URL.createObjectURL(file);

    // 3. 重新初始化裁剪区域
    $image
      .cropper("destroy") // 销毁旧的裁剪区域
      .attr("src", imgURL) // 重新设置图片路径
      .cropper(options); // 重新初始化裁剪区域
  });

  // 点击确认上传图片
  $("#upload").on("click", function () {
    // 1.拿到用户裁剪之后的头像,并转成base64位字符串格式
    let dataURL = $image
      .cropper("getCroppedCanvas", {
        // 创建一个 Canvas 画布
        width: 100,
        height: 100,
      })
      .toDataURL("image/png");

    // 2.发起请求
    $.ajax({
      type: "POST",
      url: "/my/update/avatar",
      data: {
        avatar: dataURL,
      },
      success: function (res) {
        if (res.status !== 0) return layer.msg("更换头像失败");
        layer.msg("更换头像成功");

        // 调用index.js中的方法 getUserInfo()
        window.parent.getUserInfo();
      },
    });
  });
});
